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GRUPPO EDITORIALE 

JACKSON 


Introduzione 

Dopo ore e ore passate in solitudine 
assieme al proprio computer, può 
capitare di dimenticarsi che anche lui, 
in fondo, ... è umano. Come tutti gli 
uomini ha malanni e acciacchi vari. 

Le sue malattie? Fatta la necessaria 
trasposizione uomo-macchina, le 
artrosi (tasti), miopia (video), sordità 
(registratore, drive), tachicardia (chip). 
La cura? Una sola: prevenzione. 

Alcuni preziosi suggerimenti su come 
trattarlo, poi possono migliorare e di 
molto, la vita. 

Ogni tanto, infine, un buon 
check up ... 


DIVISIONE GRANDI OPERE 
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Inconvenienti e 
manutenzione 

Nel corso degli anni i 
micro e i personal 
computer sono diventati 
estremamente affidabili, 
soprattutto grazie alla 
costante riduzione del 
numero di componenti 
elettronici che ne 
costituiscono le varie 
parti. L’affidabilità di un 
dispositivo elettronico 
(ed un elaboratore non 
sfugge certamente a 
questa regola) è infatti 
tanto maggiore quanto 
minore è la quantità di 
pezzi che lo 
compongono. In 
confronto ai loro 
predecessori i computer 
moderni sono quindi 
meno soggetti a guasti e 
più resistenti. 


Tuttavia, come d'altra 
parte in qualsiasi 
macchina costruita 
dall'uomo, anche nei 
calcolatori (e relative 
periferiche) si possono 
talvolta riscontrare difetti 
e malfunzionamenti, 
pregiudicando così 
l’affidabilità dell’intero 
sistema. 

In genere, i guasti più 
comuni si localizzano 
nelle parti del computer 
prevalentemente 
soggette ad usura 
meccanica; per esempio: 
tastiera, spinotti di 
alimentazione o di 
connessione, stampante 
e drive. 

Tali inconvenienti (a 
parte casi particolari e 
straordinari) fanno 
comunque parte del 
normale ciclo di vita 
della macchina: proprio 
come un’automobile può 
richiedere di tanto in 
tanto un’aggiustatina alle 
gomme o ai freni, anche 
per un computer è del 
tutto normale che si 
presenti la necessità di 
effettuare qualche 
manutenzione. 

Oggi cercheremo quindi, 
attraverso un’analisi 
delle varie parti che 
costituiscono il tuo 
elaboratore, di 
esaminare le principali e 
più comuni cause di 
possibile cattivo 
funzionamento, 


suggerendone - quando 
possibile - le soluzioni 
più corrette ed adeguate 
da applicare per 
eliminarle. 

La prima e più 
importante 
raccomandazione è 
comunque quella di 
leggere innanzitutto (e 
con attenzione) i manuali 
di utilizzo di tutti i 
dispositivi connessi al 
calcolatore: molte volte 
può infatti accadere di 
commettere un errore 
per scarsa conoscenza 
del funzionamento di un 
certo apparecchio. In 
tutti i manuali vengono 
inoltre forniti preziosi 
consigli ed informazioni 
sulle procedure di 
connessione, gestione e 
funzionamento delle 
varie unità. Spesso pochi 
minuti dedicati alla 
lettura dei manuali 
possono evitare 
parecchi giorni di attesa 
(oltre al costo in denaro) 
per le eventuali 
riparazioni conseguenti 
al non aver rispettato le 
corrette procedure 
operative. 




La tastiera posta troppo in alto 
o troppo in basso costringe 
l’operatore ad una posizione 
scorretta e innaturale. 
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La tastiera 

La tastiera è ovviamente 
una delle parti 
dell’elaboratore più 
sollecitata durante l’uso; 
per questa ragione, da 
sempre, i costruttori di 
computer dedicano 
particolare attenzione 
alla durata minima (o 
vita) che i vari tasti 


devono poter assicurare. 
Si è soliti indicare la 
durata della tastiera con 
il numero di battute 
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mediamente usufruibili 
prima di incappare in un 
qualsiasi 

malfunzionamento. Le 
moderne tastiere 
assicurano vite medie 
dell’ordine di milioni di 
battute, corrispondenti 
ad anni di uso normale 
dei vari tasti. 

Gli inconvenienti che 
possono capitare a un 
generico tasto sono 
principalmente due: 
rottura o allentamento 
della molla di ritorno o 
cattivo funzionamento 
dell’interruttore 
corrispondente al tasto 
stesso. Entrambi sono 
facilmente identificabili 
ed eliminabili con la 
semplice sostituzione del 
pezzo difettoso. 


La rottura della molla è 
certamente meno grave 
di quella dell’interruttore 
(è infatti sufficiente 
sollevare il tasto e 
sostituire la molla, 
mentre per cambiare 
l’interruttore si deve 
ricorrere all’uso del 
saldatore), tuttavia, sia in 
un caso che nell’altro, il 
guasto è riparabile con 
facilità e velocità. 

Un nemico della tastiera 
(e in genere di tutte le 
parti elettroniche) è 
inoltre costituito dalla 
polvere, che 
accumulandosi nella 
tastiera, provoca falsi 
contatti; per questo è 
buona norma coprirla 
con un panno o con un 
coperchio di quelli 
appositamente fabbricati, 
in vendita nei negozi 
specializzati. 


Il computer 

Tutte le parti componenti 
il computer vero e 
proprio sono dispositivi 
elettronici del tipo “a 
stato solido". Ciò 
significa che non vi sono 
parti meccaniche o 
elettromeccaniche in 
movimento, tranne 
l’eventuale interruttore di 
accensione e 
spegnimento. La 
conseguenza più ovvia 


ed immediata di questo 
fatto è che in pratica non 
viene richiesta alcuna 
manutenzione. 

Purché nessuno “metta 
le mani” all’interno del 
computer, i circuiti 
integrati, che in larga 
parte compongono 
l’elaboratore, possono 
funzionare (con le debite 
eccezioni) 

tranquillamente per mesi 
e mesi. 

I nemici principali delle 
varie parti circuitali sono 
facilmente identificabili: 
polvere, urti e liquidi. Per 
quanto riguarda la 
polvere vale il discorso 
fatto prima: è bene 
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coprire il computer 
quando non lo si utilizza; 
la polvere potrebbe 
infatti (oltre a favorire i 
falsi contatti) impedire il 
normale scambio 
termico tra l’ambiente 


esterno e il computer, 
provocando 
surriscaldamenti (o 
addirittura bruciature) 
dei circuiti. 

Particolari attenzioni 
vanno inoltre dedicate 
ad eventuali urti e 
vibrazioni. Un computer 
ben costruito è 
abbastanza protetto in 
questo senso, e tollera 
senza problemi 
spostamenti e trasporti, 
comprese le vibrazioni 
del bagagliaio di un’auto; 
bisogna comunque fare 
attenzione a non 
esagerare con gli 
sballottamenti, poiché a 
lungo andare, 
potrebbero insorgere 


problemi, dovuti magari 
all’allentamento di 
qualche vite o di 
qualche circuito interno. 
I personal computer 
sono quasi sempre 
molto robusti. 

Un discorso a parte 
meritano invece i liquidi. 
Versato su un circuito 
elettrico un liquido gli è 
in ogni caso fatale; 
occorre quindi evitare di 
appoggiare bicchieri o 
bottiglie sopra qualsiasi 
dispositivo elettronico. Il 
pericolo è inoltre 
duplice: primo, 
qualunque liquido 
versato accidentalmente 
provocherà un corto 
circuito all’interno 
dell’elaboratore, con 
conseguenze 
imprevedibili, ma 
sicuramente disastrose. 
Secondo, può insorgere 
un rischio per 
l’incolumità delle 
persone che si 
dovessero trovare nelle 
vicinanze. Molto meglio 
bere in un’altra stanza! 
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Il televisore 
o il monitor 


La manutenzione 
necessaria per 
conservare nel tempo 
l’efficienza e la qualità di 
un televisore o di un 
monitor è veramente 
minima e può essere 
riassunta in poche 
parole: tenerlo pulito e 
regolato correttamente. 
Anche nel caso dello 
schermo video si 
possono comunque 
considerare alcune 
elementari precauzioni. 
Primo: evitare - come al 
solito - l’accumulo di 
polvere. Secondo: 
posizionare l’unità in 
maniera che possa 
esservi un certo 
ricambio d’aria (questa 
regola è fondamentale). 
Terzo: non lasciare 
troppo a lungo la stessa 
immagine sullo schermo; 
può infatti accadere che 
i fosfori presenti sul retro 
dello stesso si 
schiariscano, 
imprimendo in 
permanenza quella 
immagine sullo schermo. 
Questo inconveniente è 
comunque molto limitato 
nei cinescopi moderni. 
Anche per l’unità video - 
in caso di mancato 
funzionamento - vale 
quanto detto a proposito 
del computer vero e 
proprio: non tentare 
assolutamente di 
effettuare riparazioni 
senza avere le 


opportune conoscenze 
teoriche e pratiche. È 
molto più facile per un 
inesperto peggiorare le 
cose invece di 
migliorarle. Inoltre - 
anche con la spina di 
alimentazione staccata 
dalla presa - all’interno 
del monitor o del 
televisore esistono delle 
parti sottoposte in 
permanenza ad 
un’elevata tensione e il 
cui contatto può risultare 
pericoloso per le 
persone. L’unica cosa da 
fare è controllare 
l’integrità del fusibile 
eventualmente inserito 
come protezione 
dell’unità e provvedere - 
nel caso fosse 
danneggiato - alla sua 
sostituzione. 

Il drive e 
il registratore 

Probabilmente i peggiori 
nemici dei dispositivi 
magnetici sono l’incuria 
e la distrazione; la quasi 
totalità dei problemi che 
essi accusano può infatti 
essere di solito 
ricondotta a queste due 
cause. È pertanto 
importante eseguire una 
periodica manutenzione 
delle varie parti che 
durante il funzionamento 
delle unità vengono più 
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utilizzate e quindi 
usurate. 

Parleremo facendo 
sempre riferimento al 
drive: le stesse 
considerazioni valgono 
comunque anche per il 
registratore. 

Per quanto riguarda il 
drive occorre verificare 
periodicamente che la 
calibrazione e 
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programmi mediante i 
quali si possono 
controllare 

automaticamente sia lo 
stato della testina che la 
velocità del motore che 
pone in rotazione il 
dischetto. Naturalmente, 
qualora venissero 
rilevate alcune 
irregolarità è necessario 
ricorrere allo specialista 
per rimettere a posto le 
cose. 

Il disallineamento della 
testina, soprattutto, è un 
inconveniente 
particolarmente subdolo. 


l’allineamento della 
testina siano corretti, 
cioè che la velocità di 
rotazione del motore e la 
posizione della testina 
rispetto al floppy disk 
siano identici a quanto 
stabilito dal costruttore. 
Per questa operazione ci 
si può rivolgere a uno 
specialista, ma volendo 
la si può effettuare 
anche per conto proprio. 
Esistono infatti in 
commercio dei 
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Usando il drive con la 
testina non allineata, di 
solito tutto sembra infatti 
funzionare nel migliore 
dei modi: le registrazioni 
e le letture dei dischetti 
avvengono normalmente, 
senza alcun errore o 
anomalia. Se si tenta 
tuttavia di leggere un 
disco registrato da 
un’altra unità (o, 
viceversa, di leggere su 
un’altra unità un disco 


già registrato), 
l’operazione risulta 
impossibile. 

Questo fatto è diretta 
conseguenza della 
posizione della testina 
che indica al drive la 
presenza di registrazioni 
diverse da quelle che si 
aspettava. In un certo 
senso il lettore di dischi 
riconosce solo le proprie 
registrazioni, 
“personalizzate” dal 
disallineamento della 
testina stessa. 

Di solito un drive 
richiede di essere 
verificato una o due 
volte all’anno. 

Ben più frequente deve 
essere invece la pulizia 
della testina. Essa va 
infatti pulita 
regolarmente, per 
eliminare la presenza di 
polvere e di particelle di 
ossido che su di essa si 
depositano in seguito al 
contatto con il disco. Il 
numero di puliture 
necessarie dipende 
dall'ambiente (più o 
meno polveroso) in cui il 
drive opera e 
dall’intensità di utilizzo 
alla quale viene 
sottoposto. A questo 
scopo sono disponibili 
speciali floppy disk, 
appositamente ideati per 
facilitare l’operazione. 
Come regola generale, la 
testina del drive 
andrebbe pulita almeno 


una volta ogni tre mesi. 
La velocità e la 
semplicità 
dell’operazione 
consigliano tuttavia un 
intervento anche più 
frequente. 

Occorre infine ricordarsi 
che anche i drive sono 
meccanismi sensibili; 
quando si sposta un 
drive si deve quindi, 
come al solito, cercare 
di evitare urti e 
vibrazioni. 

Un drive ben curato può 
lavorare per anni senza 
alcun problema, purché 
si faccia sempre un 
minimo di attenzione (e 
di manutenzione). 


La stampante 

In quasi tutti i sistemi la 
stampante è il 
dispositivo con il 
maggior numero di parti 
meccaniche, ed è quindi 
quello con maggiori 
probabilità di guasti, 
soprattutto se impiegato 
in modo anomalo o 
scorretto. Dato che una 
stampante ha tante parti 
mobili, risente 
particolarmente di un 
uso violento. Vediamo 
come comportarsi. 

La stampante dovrebbe 
innanzitutto poggiare su 
un supporto stabile, per 
evitare vibrazioni che ne 
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disturbino il lavoro. 

Dietro e davanti alla 
stampante ci dovrebbe 
inoltre essere uno spazio 
sufficiente per poter 
accedere alla carta in 
entrata e in uscita. 

La carta va inserita 
correttamente nel 
meccanismo di trazione. 
Può sembrare una 
considerazione evidente, 
però è facile infilare la 
carta storta, provocando 
talvolta il blocco della 
stampante. Occorre 
quindi imparare a 
rispettare sempre la 
disposizione della carta. 
Un blocco della stessa è 
quasi sempre dovuto ad 
un'ostruzione fisica; di 
solito la carta si blocca 
perché i controlli sono 
regolati male, perché è 
stata inserita in modo 


scorretto o perché si 
sono utilizzati fogli non 
idonei. 

Quando la carta si 
blocca il motore della 
stampante può bruciare: 
è quindi bene non 
assentarsi mai durante il 
funzionamento. Anche il 
nastro inchiostrato (nelle 
stampanti ad aghi e a 
margherita) deve essere 
sempre tenuto sotto 
controllo; bisogna 
saperlo inserire in modo 
corretto, facendo 
attenzione alle eventuali 
pieghe che possono 
sempre verificarsi 
durante il montaggio. 

La testina della 
stampante è una delle 
parti maggiormente 
soggette ad usura, tanto 
che è quasi normale che 
a un certo punto si 
rompa. In questo caso 
l’unica cosa da fare è 
provvedere alla 
sostituzione. 

Nel caso di guasto 
parziale o totale della 
stampante è bene 
eseguire nell’ordine 
queste operazioni: 

— controllare che la 
posizione e l’inserimento 
dei cavi di alimentazione 
e di collegamento con il 
computer siano corretti; 

— verificare tutti gli 
interruttori e i tasti di 
controllo; 

— controllare lo stato 
del fusibile; 


— controllare il 
meccanismo di stampa, 
il nastro e la carta; 

— a questo punto, se le 
cose non sono ancora 
andate a posto, far 
controllare la stampante 
presso un centro di 
assistenza tecnica. Mai 
utilizzare olio o altri 
lubrificanti, se non 
indicato espressamente 
nel manuale di istruzioni. 
Come al solito, le 
raccomandazioni del 
manuale vanno lette e 
seguite con attenzione. 
Ricorda: qualunque 
stampante funzionerà in 
modo corretto, purché 
sia regolata in maniera 
appropriata e a 
condizione che vengano 
effettuate con regolarità 
le adeguate operazioni 
di manutenzione 
richieste dall’unità. 

I cavi 

di connessione 

Ai cavi di collegamento 
vanno dedicate 
particolari cure ed 
attenzioni, essendo 
fondamentali per il buon 
funzionamento di tutto il 
sistema. 

Poiché il punto più 
debole dei cavetti risulta 
essere quello dove il 
cavo termina nello 
spinotto, occorre essere 
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molto diligenti 
nell’osservare alcune 
semplici ed elementari 
precauzioni, deducibili 
comunque anche con un 
minimo di buon senso: 

— evitare sempre e 
comunque di estrarre gli 
spinotti dalle prese 
tirandoli per il cavetto: 
questa operazione risulta 
spesso fatale per la 
continuità elettrica 
assicurata dallo spinotto; 

— cercare, nei limiti del 
possibile, di far compiere 
ai cavetti poche pieghe 
brusche; 

— limitare al massimo le 
operazioni di inserzione 
e disinserzione: infatti le 
prese e gli spinotti 
subiscono nel corso di 


individuare il punto di 
rottura (di solito cedono 
sempre le saldature) e 
con un piccolo saldatore 
rimettere a posto le 
cose. Evitare riparazioni 
diverse dalla saldatura 
(tipo giunzioni con 
nastro adesivo, viti, fili 
aggiunti, ecc.); 

— controllare che il 
contatto avvenga sempre 
nel migliore dei modi, 
eliminando le eventuali 
tracce di ossido o 
sporcizia con uno 
straccetto imbevuto di 
sostanze solventi, tipo 
alcool o benzina. 


queste manovre una 
sollecitazione che nel 
tempo tende a 
peggiorare il contatto 
elettrico. È senz’altro 
utile ripristinare di tanto 
in tanto il migliore 
contatto, agendo con 
delicatezza sullo spinotto 
mediante una piccola 
pinza; 

— in caso di guasto la 
riparazione del cavo è 
molto semplice: basta 
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Interpreti 
e compilatori 


Quando scriviamo un 
programma in BASIC è 
facile dimenticare che in 
realtà il nostro computer 
non è in grado di capire 
quei comandi che noi gli 
impartiamo, ma può 
eseguire soltanto 
istruzioni date secondo 
una sequenza di numeri 
binari. Questi numeri, 
che costituiscono la 
lingua nativa del 
microprocessore del 
computer, vengono 
quindi forniti 
dall’interprete BASIC, 
che nel corso 


dell’esecuzione traduce 
una dopo l’altra le varie 
istruzioni componenti il 
programma. 

L’interprete BASIC nei 
confronti dell'elaboratore 
si comporta esattamente 
come un traduttore 
simultaneo, che decifra 
istantaneamente ciò che 
gli viene detto in frasi 
comprensibili ed 
eseguibili dalla CPU. 
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Agli effetti pratici 
possiamo pertanto 
immaginare l’interprete 
come una specie di 
scatola magica alla 
quale vengono fornite in 
entrata le istruzioni 
BASIC e che in uscita 
risponde con ordini 
“digeribili” dall’unità 
centrale. 

In realtà l’interprete 
BASIC è anch’esso un 
programma vero e 


proprio, il cui compito è 
appunto quello di 
tradurre le istruzioni 
BASIC in istruzioni in 
linguaggio macchina. 

Per quanto veloce ed 
ottimizzato possa essere, 
il programma traduttore 
richiede tuttavia un certo 
intervallo di tempo per 
poter svolgere il proprio 
lavoro: in altre parole, la 
traduzione da istruzioni 
BASIC a istruzioni in 
linguaggio macchina 
necessita di un certo 
lavoro e di conseguenza 
introduce un certo 
rallentamento 
nell’esecuzione. 

La cosa può apparire 
alquanto ingarbugliata: 
perché ricorrere al 


traduttore quando si 
potrebbe scrivere il 
programma direttamente 
in istruzioni eseguibili 
dal microprocessore, 
ottenendo per giunta le 
risposte molto più in 
fretta? La risposta trova 
giustificazione 
nell’enorme sforzo che 
richiede - a confronto 
della programmazione in 
BASIC - la scrittura di 
programmi in linguaggio 
macchina. 

Certamente i risultati e le 
risposte con la 
programmazione in 
assembler (così viene 
anche chiamato il 
linguaggio macchina) 
risultano molto più veloci 
e immediati, tuttavia il 
tempo necessario a 
risolvere e scrivere uno 
stesso programma in 
assembler e in BASIC è 
nettamente a favore del 
BASIC (mediamente il 
rapporto è di uno a 
venti). 

L’interprete è quindi 
l’anello di congiunzione 
tra l’uomo e la 
macchina, cioè 
l’elemento che permette 
di realizzare una 
reciproca e perfetta 
comprensione. 

Però, come detto prima, 
dato che l’interprete 
deve leggere ogni volta 
le varie istruzioni, 
analizzarle, verificare la 
correttezza della sintassi 

13 



LINGUAGGIO 


ed eseguire le 
operazioni richieste, la 
velocità di lavoro non 
può che risentirne, 
risultando notevolmente 
inferiore a quella che il 
programma potrebbe 
avere se fosse scritto 
direttamente in 
linguaggio macchina. 


Da queste 

considerazioni risulta 
chiaro che, per quanto 
di gran lunga superiore 
a quella di qualunque 
essere umano, la 
velocità di esecuzione di 
un programma BASIC 
non potrà mai superare 
un certo livello. 

Si potrebbe pensare, per 
aumentarla, di tradurre 
manualmente il 
programma BASIC in un 
programma 

corrispondente scritto in 
linguaggio macchina, ma 
sarebbe un’operazione 
alquanto lunga e noiosa, 
da ripetersi poi ad ogni 
variazione del 
programma. 


Le operazioni 
meccaniche, lunghe, 
noiose e ripetitive sono 
proprio il genere di cose 
che possiamo far 
eseguire a un 
calcolatore: basterà 
allora scrivere (una sola 
volta) un programma che 
traduca ciascuna 
istruzione BASIC in una 
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corrispondente routine in 
linguaggio macchina, e i 
nostri “problemi” 
saranno risolti. Un 
programma del genere si 
chiama compilatore 
BASIC: legge il nostro 
testo e, con pazienza, 
scrive (o, meglio, 


compila) un programma 
in linguaggio macchina 
che fa il medesimo 
lavoro. 

Il primo vantaggio di un 
programma compilato è 
l’eliminazione del 
procedimento di 
interpretazione delle 
istruzioni. Inoltre, dato 
che la sintassi viene 
controllata durante la 


compilazione, si 
risparmia ulteriore tempo 
e, tra l’altro, non c’è più 
il rischio che il 
programma contenga 
errori di sintassi non 
rilevati. 

Ma il vantaggio 
maggiore viene dal fatto 
che il compilatore, 
avendo la possibilità di 
leggere l’intero testo 
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BASIC, può eliminare le 
lente operazioni di 
ricerca delle linee (che 
l’interprete BASIC deve 
invece eseguire ad ogni 
GOTO o GOSUB) e delle 
variabili (per utilizzare 
una variabile occorre 
infatti che il traduttore 
compia un certo numero 
di operazioni, 
principalmente rivolte 
all’analisi della posizione 


occupata nella memoria 
da quella variabile). 

Per tutti questi fattori la 
velocità di un 
programma compilato è 
notevolmente superiore 
a quella dello stesso 
programma interpretato. 
Naturalmente, anche la 
compilazione ha i suoi 
svantaggi: 

— il programma, di 
solito, aumenta di 
dimensioni; 

— ci sono spesso 
istruzioni disponibili con 
l’interprete e non con il 
compilatore; 

— il lavoro di 
compilazione richiede 
tempo (anche diversi 
minuti); 

— non è possibile 
arrestare il programma 
compilato e riprenderlo 
dopo aver magari fatto 
stampare il valore di 
qualche variabile (cosa 
perfettamente lecita nel 
BASIC interpretato); 

— ogni modifica va fatta 
sul testo originario, che 
va poi nuovamente 
compilato. 

Si preferisce di solito 
scrivere il programma in 
BASIC normale (cioè 
interpretato), metterlo a 
punto e collaudarlo a 
fondo, e poi compilarlo. 
Un programma 
compilato non è più in 
BASIC, ma in linguaggio 
macchina. Di 
conseguenza non può 


essere caricato in 
memoria con un 
semplice LOAD, o fatto 
partire con RUN, ma 
occorre usare altri 
comandi. 

Da quello che abbiamo 
detto fino a questo punto 
sembrerebbe che un 
compilatore sia 
estremamente più 
vantaggioso di un 
interprete. In realtà, 
ognuno dei due presenta 
specifiche 

caratteristiche, alcune 
vantaggiose, altre 
svantaggiose, valutabili 
soltanto analizzando il 
singolo problema. Tieni 
comunque presente che 
per quanto riguarda la 
facilità e la flessibilità di 
utilizzo l’ago della 
bilancia pende 
nettamente a favore 
dell’interprete, mentre 
dal punto di vista della 
velocità di esecuzione le 
cose volgono in 
direzione del 
compilatore. 
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Rappresentazi 
dei numeri 


Finora abbiamo sempre 
evitato qualsiasi cosa 
che non fosse aritmetica 
abbastanza semplice, e 
continueremo a fare 
così. Ma sarebbe 
sbagliato non dare un 
breve sguardo alle 
capacità aritmetiche del 
computer e soprattutto 
alla rappresentazione dei 
numeri nei computer. 
L’elaborazione di un 
dato richiede infatti che 
lo stesso sia contenuto 
nella memoria 
dell’elaboratore in una 
forma immediatamente 
utilizzabile dall’unità 
centrale. Poiché l’unica 
rappresentazione 
riconoscibile dalla CPU 
è quella digitale, anche i 
numeri devono quindi 
essere espressi in tale 
forma. 

Conosci già come si fa a 
passare dalla notazione 
decimale a quella binaria 
e viceversa, e quindi non 
ci soffermeremo a 
parlare di questo 
argomento. 

Esamineremo invece 
alcuni aspetti piuttosto 
interessanti che 
emergono nell’uso 
pratico dei numeri col 
computer. 

Innanzitutto, il principale 
consiglio è quello di 
esaminare sempre con 
una certa dose di 
diffidenza qualsiasi 
numero che sia stato 


utilizzato all’interno di un 
programma. La ragione 
di questo suggerimento 
è che i numeri all’interno 
del computer, a causa 
della conversione da 
decimali a binari, 
subiscono quasi sempre 
arrotondamenti o 
troncamenti, che ne 
modificano - per quanto 
leggermente - l'esatto 
valore. Per esempio, 
nella nostra familiare 
notazione decimale ti 
ricorderai certamente 
che un numero come 
1/3o 1/7 non è in 
grado di avere 
un’espressione esatta: 

1 /3=0.333333.Noi 

diamo per scontato che 
aggiungendo al numero 
tanti 3 quanti ne 
vogliamo possiamo 
ottenere un grado di 
approssimazione 
accettabile in qualsiasi 
particolare problema. Nel 
sistema binario, allo 
stesso modo, alcuni 
numeri non possono 
essere espressi 
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esattamente.Nonostante 
il tuo MSX sia uno dei 
più precisi tra i computer 
della sua categoria devi 
tener presente che i 
numeri all’Interno della 
memoria possono subire 
delle alterazioni. 

Esistono infatti dei limiti 
al numero di cifre che 
un computer è in grado 
di trattare: numeri troppo 
grandi o troppo piccoli 
devono essere quasi 
necessariamente 
arrotondati. Vediamo 
meglio questo fatto. 


Un numero molto grande 
(oppure molto piccolo) 
può essere 

rappresentato mediante 
la cosiddetta notazione 
scientifica, cioè con una 
forma abbreviata del 
numero stesso, nella 
quale si indica la 
potenza di 10 alla quale 
il numero va elevato, 
preceduta dalla lettera 
“E" (in pratica, di quante 
cifre va spostata la 
virgola). La parte a 
sinistra delle E si chiama 
mantissa, la successiva 
esponente: 


Forma normale 

Notazione scientifica 

1000000 

0.00000001 

0.000586321 

93000000000 

1E+06 

1E-07 

0.586321 E-3 

0.93E+11 


Il calcolatore, al 
momento 

dell’introduzione dei 
numeri in forma normale, 
lì trasformerà 
internamente in questo 
formato (chiamato anche 
in virgola mobile), 
consistente nel porre il 
punto decimale dopo la 
prima cifra significativa e 
aggiustare di 
conseguenza 
l’esponente. 
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Naturalmente, se la 
mantissa supera una 
certa lunghezza alcune 
cifre vanno perdute. 
Così, i due numeri 


12.0000000000001 
12.0000000000004 


per il tuo computer non 
sono distinguibili e 
l’informazione meno 
significativa viene 
perduta. 

Introduci però 


? 12.0000000000001 
? 12.000000000000006 


Visto la differenza? 

Il tuo MSX è davvero 
forte: opera infatti su ben 
14 cifre significative ed è 
in grado di valutarne la 
15 a per arrotondamento. 
Naturalmente, ci sono 
dei limiti anche per 
l’esponente. Quando il 
BASIC stampa un 
numero, lo fa in formato 
normale, a meno che 
questo comporti un 
numero di cifre 
maggiore della sua 
precisione, nel qual caso 
passa al formato 
esponenziale. Questo 
esempio ti illustrerà 
meglio quanto detto: 


10 PRINT “NUMERO”, "RAPPRESENTAZIONE" 

20 PRINT 

30 FORI=1T015 

40 PRINT “1”; ” E+";l, 10 A I 

50 NEXT 
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Funzioni 

numeriche 


Ormai abbiamo quasi 
terminato l’esame delle 
varie funzioni disponibili 
sul tuo MSX: infatti, ce 
ne restano ancora 
soltanto due. Tra poco 
vedremo tuttavia come 
sia possibile, attraverso 
un utile e potente 


strumento fornito dal 
BASIC, creare e definire 
a proprio piacere 
qualsiasi altra funzione, 
che non faccia già parte 
del gruppo inserito nella 
macchina sin dalla 
fabbrica. 
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EXP 


La funzione 
esponenziale viene 
utilizzata per elevare il 
numero “e” a una certa 
potenza. Essa calcola 
cioè il valore della 
costante e (base dei 
logaritmi cosiddetti 
naturali) elevato alla 
potenza fornita 
dall’argomento 
specificato. 

Il numero e è un 
particolare valore, che 
viene definito 
matematicamente in una 
forma molto precisa, ma 


di cui il tuo MSX utilizza 
una approssimazione 
pari a 2.7182818284588. 
Vediamola subito al 
lavoro: 


PRINT EXP(1) 


dice al computer di 
visualizzare il risultato di 
e elevato alla 1. Sullo 
schermo apparirà quindi 
il valore 

2.7182818284588. 
L’origine di questo 
valore è abbastanza 
complessa; questo breve 
programma ti illustrerà 
tuttavia come esso 
possa essere ottenuto in 
forma approssimata: 


10 FOR 1=1 TO 1000 
20 LET E=(1+1/l) Al 
30 PRINT E, EXP(1) 

40 NEXT I 


Sulla sinistra dello 
schermo apparirà infatti 
una serie di numeri, che 
all’aumentare di I 
tenderà ad essere 
sempre più prossima al 
valore di e fornito dalla 
funzione EXP (visibile 
sulla destra). 


LOG 


La funzione LOG si 
utilizza invece per 
compiere l’operazione 
esattamente opposta a 
quella eseguita con EXP. 
LOG calcola infatti il 
logaritmo naturale, cioè 
in base e, 
dell’argomento. 

Così, se e è il risultato di 
EXP(1), LOG(e) risulterà 
1. Gli argomenti si 
scambiano con i risultati 
e viceversa. 

Il logaritmo è una 
funzione particolarmente 
utile e preziosa in 
numerosi calcoli 
matematici, poiché 
permette di abbreviare 
conti ed operazioni, 
grazie ad alcune 
importanti proprietà di 
cui essa gode. 
Soprattutto nella tecnica 
e nei calcoli scientifici è 
quindi di basilare 
importanza disporre 
dell’uso dei logaritmi. 

Se comunque non ne 
conosci le regole di 
utilizzo, non ti 
preoccupare: visto che 
non ne hai avuto 
bisogno fino ad ora, 
forse i logaritmi non ti 
serviranno neppure in 
futuro. Nel caso tu 
comunque desiderassi 
usarla lo stesso (magari 


Sintassi della funzione 


EXP (espressione) 
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per generare strani 
numeri o cose del 
genere), ricordati di non 
assegnare mai a LOG un 
argomento negativo o 
nullo. Proprio come la 
funzione SOR, anche 
LOG non può lavorare 
su numeri minori di zero 
(e nemmeno sullo zero). 

Sintassi della funzione 


LOG (espressione) 


DEF FN 


Capita spesso che nello 
stesso programma siano 
presenti calcoli od 
espressioni simili; in tal 
caso è possibile scriverli 
una sola volta, per poi 
richiamarli con una 
subroutine. 

Queste ultime hanno 
però lo svantaggio di 
lavorare con i nomi di 
variabili specificate nella 
routine stessa. 

Ad esempio, se 
volessimo approssimare 
all’intero più vicino il 
valore di un certo 
numero, potremmo 
scrivere una cosa del 
genere: 


100 REM APPROSSIMA ALL’INTERO 
110 REM PIU’ VICINO IL VALORE DI X 
120 X=INT(X+.5) 

130 RETURN 


Questa subroutine 
fornisce però soltanto la 
media dei valori 
contenuti nella sola 
variabile X. 

Potrebbe darsi che nel 
nostro programma 
avessimo bisogno di 
arrotondare anche i 
valori di P e di Q. Per 
usare la subroutine 
dovremmo riassegnare i 
valori delle variabili ogni 
volta: 
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variabili interessate, 
scrivendo quindi SQR(A) 
per ottenere la radice 
quadrata di A e SQR(Z) 
per ricavare quella di Z. 


In tutte le funzioni 
presenti sul MSX si fa 
però riferimento alle 




20 LET X=P : GOSUB 100 : LET P=X 
30 LET X=Q : GOSUB 100 : LET Q=X 
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Definendo una nuova 
funzione, potremmo 
analogamente 
specificare la variabile 
su cui fare le operazioni. 
Il BASIC consente al 
programmatore di 
definire nuove funzioni 


matematiche, utilizzabili 
in seguito come se 
facessero parte del 
linguaggio stesso. 

Per definire una nuova 
funzione bisogna 
inserire nel programma 
una istruzione del tipo 


Nel caso del nostro 
esempio la soluzione 
avrebbe quindi potuto 
essere: 


DEF FN nome (argomento)=espressione 


10 DEF FN R(X)=INT(X+.5) 


Da quel punto in avanti 
la funzione sarebbe stata 
considerata come 
definita e il computer 
l’avrebbe eseguita in 
tutta tranquillità. 
L’istruzione DEF FN 
consente quindi di 
definire nuove funzioni, 
oltre a quelle facenti 
parte del linguaggio vero 
e proprio. 

Approfondiamo meglio la 
sintassi da utilizzare: 

— DEF FN è una parola 
riservata, che indica 
all’elaboratore di definire 
una nuova funzione; 

— nome è la parola che 
verrà impiegata nel resto 
del programma per 
chiamare la funzione 
definita con DEF FN; 
essa deve rispettare le 
stesse regole di 


formazione dei nomi 
delle variabili numeriche 
decimali; 

— argomento è la 
variabile che serve per 
definire gli operandi sui 
quali interverrà la 
funzione; 

— espressione indica 
invece le operazioni che 
il computer dovrà 
eseguire per giungere al 
risultato. 

Dopo che il programma 
ha eseguito la linea 


DEF FN R(X)=INT(X+.5) 


la funzione R(X) diventa 
quindi una parola 
riservata del BASIC e 
può essere usata come 
fosse parte del 
linguaggio. 

Per esempio: 


300 A=FN R(C) 


vuol dire: calcola il 
valore di A, applicando 
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al valore di C la funzione 
R definita prima. 

La X, che abbiamo usato 
alla linea 10 per definire 
la funzione, viene 
sostituita con il valore 
della espressione che 
segue FN R, cioè con il 
valore di C. Si dice 
quindi che X è un 
parametro formale (o 


parametro fittizio), cioè 
ha il solo scopo di 
indicare dove va 
impiegato l’argomento 
della funzione quando 
questa viene chiamata. 
Naturalmente, perché il 
BASIC possa 
riconoscerla, la 
definizione della 
funzione (cioè 


l’esecuzione della linea 
di programma che la 
definisce) deve avvenire 
prima che la funzione 
possa essere richiamata. 
Qui sotto puoi trovare 
una serie di funzioni 
matematiche che non 
sono comprese nel 
BASIC standard, ma che 
è possibile definire 
mediante DEF FN nel 
momento in cui esse si 
rendessero 
eventualmente 
necessarie: 


SEC(X)=1 /COS(X) 

CSC(X)=1 /SIN(X) 

COT(X)=1 /TAN(X) 

ARCSIN(X)=ATN(X/SQR(-X*X+1)) 

ARCCOS(X)=-ATN(X/SQR(-X*X+1))+1.5708 


Secante 
Cosecante 
Cotangente 
Arcoseno (Seno inverso) 
Arcocoseno 
(Coseno inverso) 

ARCSEN(X)=ATN(SQR(X*X-1 ))+(SGN(X)-1 )* 1.5708 Arcotangente 

(Tangente inversa) 

ARCCSC(X)=ATN(1/SQR(X*X-1))+(SGN(X)-1)*1.5708 Cosecante 

inversa 

ARCCOT(X)=-ATN(X)+1.5708 
SINH(X)=(EXP(X)-EXP(-X))/2 
COSH(X)=(EXP(X)+EXP(-X))/2 
TANH(X)=-EXP(-X)/(EXP(X)+EXP(-X))*2+1 
SECH(X)=2/(EXP(X)+EXP(-X)) 

CSCH(X)=2/(EXP(X)-EXP(-X)) 
COTH(X)+EXP(-X)/(EXP(X)-EXP(-X))*2+1 
ARGSINH(X)=LOG(X+SQR(X*X+1 )) 
ARGCOSH(X)=LOG(X+SQR(X*X-1)) 

ARGTANH(X)=LOG((1 +X)/(1 -X))/2 
ARGSECH(X)=LOG((SQR(-X*X+1 )+1 ) 


Cotangente inversa 
Seno iperbolico 
Coseno iperbolico 
Secante iperbolica 
Tangente iperbolica 
Cosecante iperbolica 
Cotangente iperbolica 
Seno iperbolico inverso 
Coseno iperbolico inverso 
Tangente iperbolica inversa 
Secante iperbolica inversa 


ARGCSCH(X)=LOG(SGN(X)*SQR(X*X+1)+1)/X Cosecante iperbolica 

inversa 

ARGCOTH(X)=LOG((X+1)/(X-1))/2 Cotangente iperbolica inversa 
MOD(A)=INT((A/B-INT(A/B))*B+.05)*SGN(A/B) Modulo 

LOGB(X)=LOG(X)/LOG(B) Logaritmo in base B 
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Esempi 


10 DEF FN A(R)=R*R*3.14 
20 LET X=2 
30 PRINT FN A(X) 


Definisce una funzione 
(il cui nome è A) avente 
come scopo quello di 
calcolare l’area del 
cerchio di raggio R. R è 
il parametro formale. 

La linea 20 calcola l’area 
del cerchio di raggio 2. 

X costituisce invece il 
parametro reale. 


10 DEF FN SEN(X)=SIN(X) 

__ 


Definisce una nuova 
funzione, chiamata S, 
che esegue la stessa 
operazione della 
funzione intrinseca SIN. 


40 PRINT FN SEN(3) 
50 PRINT SIN(3) 


L’effetto di queste 
istruzioni sarà quindi la 
stampa di due valori 
assolutamente identici. 


90 DEF FN A(X)=PEEK(2040)+PEEK(2041)*256 


Questa funzione fornisce 
come risultato un valore 
indipendente 
dall’argomento utilizzato. 
È infatti perfettamente 
lecito (sempre 
rispettando le regole 
imposte dall’istruzione) 
definire delle funzioni 
che, nonostante lo 
richiedano, non 
utilizzano l’argomento 
all’interno 
dell’espressione. 
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100 PRINT FN A(0) 


Stamperà il risultato del 
calcolo sul contenuto 
delle locazioni 2040 e 
2041. 


20 DEF FN SOM(X)=3+SIN(2.3) 
30 PRINT FN SOM(41) 

40 PRINT FN SOM(3.82) 


Anche in questo caso 
l’argomento non avrà 
alcuna influenza sul 
risultato, visto che non 
compare 

nell’espressione. Le due 
istruzioni di stampa, 
nonostante richiamino 
funzioni con argomento 
differente, produrranno 
quindi risultati identici. 


Sintassi della funzione 


DEF FN nome funzione (variabile [ , variabile ] ) = espressione 
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PROGRAMMAZIONE 


Disegno 
di un grafico 


Adesso che sappiamo 
definire a nostro piacere 
tutte le funzioni che 
vogliamo ci è possibile 
scrivere un programma 
per eseguire un’utile e 
tutto sommato divertente 
operazione: il 
tracciamento del grafico 
di una funzione. 

Per raggiungere questo, 
obiettivo dobbiamo 
naturalmente riprendere 
quelle istruzioni 
elementari che avevamo 
introdotto qualche 
lezione fa, parlando della 
grafica, e che ci 
serviranno per il 
tracciamento dei singoli 
punti che comporranno 
la funzione. 

Dal punto di vista 
concettuale la scrittura 
del programma non è 
molto difficile: basta 
definire la funzione che 
desideriamo disegnare e 
procedere al 

tracciamento punto dopo 
punto. 

Un pochino più 
complicato risulta invece 
l’utilizzo del programma: 
bisognerà infatti fare 
sempre attenzione alla 
funzione che vorremo 


disegnare. Accade 
spesso che alcune 
funzioni non siano 
definite (cioè non 
esistano) in 
corrispondenza di 
determinati valori 
dell’argomento. Per 
esempio, la funzione 
SQR non ammette 
argomenti negativi (non 
esiste la radice quadrata 
di un numero negativo!), 
quindi qualsiasi tentativo 
di eseguire dei calcoli 
con numeri minori di 
zero incontrerà 
immediatamente lo 
sbarramento impostoci 
dal messaggio di errore. 
Questa eventuale 
limitazione è molto 
semplice da individuare 
nel caso di funzioni 
semplici (come SQR), 
mentre risulta di estrema 
difficoltà quando la 
funzione stessa si 
complica (chi è in grado 
di dire subito dove non è 
definita 

LOG(SIN(TAN(X))* 

SQR(COS(X)))?). 

Visto comunque che 
l’unica conseguenza di 
una situazione di questo 
tipo è al massimo la 
visualizzazione di un 
messaggio di errore, si 
potrà sempre (anche se 
forse non è la soluzione 
più elegante) procedere 
per tentativi. 

Ecco lo schema a 
blocchi del programma: 
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INIZIO 


DEFINISCI FUNZIONE 


MODO GRAFICO 


X = 1 


CALCOLA Y 


VISUALIZZA IL 
PUNTO 


X =X + 1 



Ed ecco il 

corrispondente listato: 

10 DEFFN FUNZ(X)=SIN(X) : CLS 
20 SCREEN2 
30 FOR X=1TO 255 
40 Y=INT(96+95*FN FUNZ(X/20)) 
50 PSET(X,Y) 

60NEXT _ 

70 A$=INKEY$ : |FA$=‘”’THEN70 
80 RUN 


Gli abbondanti 
commenti e l’uso 
frequente delle 
subroutine rendono il 
programma abbastanza 
semplice da leggere e 
da capire. 


Per cambiare la funzione 
da tracciare l’unica 
modifica necessaria è 
quella di sostituire alla 
linea 10 l’espressione 
della vecchia funzione 
(che attualmente è 
SIN(X)) con la definizione 
della nuova. 

A titolo di possibile 
miglioramento prova 
come esercizio a far 
tracciare - prima del 
grafico vero e proprio - 
anche i due assi 
cartesiani presi come 
sistema di riferimento 
(attenzione che bisogna 
considerare varie 
possibilità!). 
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PROGRAMMAZIONE 


Programma 

finanziario 


Il programma seguente 
fa uso della formula: 

T = LN (CF/Q/LN (I) 


per calcolare il tempo 
necessario affinché un 
determinato capitale 
inizia (CI) possa 
diventare uguale al 
capitale finale (CF) ad un 
certo tasso di interesse 

(I). 

Nota la funzione definita 
nella prima linea il cui 
compito è quello di 
eseguire 

l’arrotondamento del 
tempo calcolato. 
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PROGRAMMAZIONE 


DEFIN. 
FN A (N) 


IMM. <CI > 

< CF > < I > 



10 DEFFNA(N)=INT(N + .5) 

20 CLS : INPUT "Capitale iniziale" ; CI 
30 INPUT "Capitale finale” ; CF 
40 INPUT “Interesse” ; I 
50 1=1+1/100 
60 T=LOG(CF/CI)/LOG(l) 

70 PRINT "tempo— ’ ; FNA(T) 

80 INPUT "ancora” ; R$ 

90 IF R$=‘‘s" OR R$=‘‘S"THEN 20 
100 END 
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Sulla scorta degli esempi riportato puoi dotare il tuo MSX di funzioni molto utili. 
Basterà unire la necessità e la conoscenza di DEF FN per ottenere risultati 
sorprendenti. 


10 DEF FNCUBO(X)=X A 3 : CLS 
20 INPUT “fornisci un numero"; N% 

30 PRINT "il cubo di”;N%;“è”; FNCUBO(N%) 
40 INPUT “ancora s/n"; A$ 

50 IF A$=“s” THEN RUN:ELSE END 


10 DEF FNPOTENZA(X,Y)=X A Y 
20 INPUT “numero="; A 
30 INPUT “esponente-’; B 
40 RIS=FNPOTENZA(A,B) 

50 PRINT “risultato=”; RIS 
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